UM10360 Chapter 18: LPC176x/5x SSP0/1

User manual

### 18.1 Basic configuration

The two SSP interfaces, SSP0 and SSP1 are configured using the following registers:

1. Power: In the PCONP register (Table 46), set bit PCSSP0 to enable SSP0 and bit PCSSP1 to enable SSP1.

Remark: On reset, both SSP interfaces are enabled (PCSSP0/1 = 1).

- 2. Clock: In PCLKSEL0 select PCLK\_SSP1; in PCLKSEL1 select PCLK\_SSP0 (see Section 4.7.3. In master mode, the clock must be scaled down (see Section 18.6.5).
- 3. Pins: Select the SSP pins through the PINSEL registers (Section 8.5) and pin modes through the PINMODE registers (Section 8.4).
- 4. Interrupts: Interrupts are enabled in the SSP0IMSC register for SSP0 and SSP1IMSC register for SSP1 Table 376. Interrupts are enabled in the NVIC using the appropriate Interrupt Set Enable register, see Table 50.
- 5. Initialization: There are two control registers for each of the SSP ports to be configured: SSP0CR0 and SSP0CR1 for SSP0, SSP1CR0 and SSP1CR1 for SSP1. See Section 18.6.1 and Section 18.6.2.
- 6. DMA: The Rx and Tx FIFOs of the SSP interfaces can be connected to the GPDMA controller (see Section 18.6.10). For GPDMA system connections, see Table 544.

Remark: SSP0 is intended to be used as an alternative for the SPI interface, which is included as a legacy peripheral. Only one of these peripherals can be used at the any one

### 18.2 Features

- . Compatible with Motorola SPI, 4-wire TI SSI, and National Semiconductor Microwire buses.
- · Synchronous Serial Communication.
- · Master or slave operation.
- . 8 frame FIFOs for both transmit and receive.
- 4 to 16 bit data frame.
- · DMA transfers supported by GPDMA.

#### 18.3 Description

The SSP is a Synchronous Serial Port (SSP) controller capable of operation on a SPI, 4-wire SSI, or Microwire bus. It can interact with multiple masters and slaves on the bus. Only a single master and a single slave can communicate on the bus during a given data transfer. Data transfers are in principle full duplex, with frames of 4 to 16 bits of data flowing from the master to the slave and from the slave to the master. In practice it is often the case that only one of these data flows carries meaningful data.

The LPC176x/5x has two Synchronous Serial Port controllers -- SSP0 and SSP1.

© NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers UM10360 User manual Rev. 4. 1 - 19 December 2016 423 of 851

UM10360 **NXP Semiconductors** Chapter 18: LPC176x/5x SSP0/1

18.4 Pin descriptions

Table 369. SSP pin descriptions

| Pin     | Type | Interface pin name/function |                | 1              | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|------|-----------------------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name    | ,,,  | SPI                         | SSI            | Microwire      |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SCK0/1  | I/O  | SCK                         | CLK            | SK             | Serial Clock. SCK/CLK/SK is a clock signal used to synchronize the transfer of data. It is driven by the master and received by the slave. When the SPI interface is used, the clock is programmable to be active-high or active-low, otherwise it is always active-high. SCK1 only switches during a data transfer. Any other time, the SSPn interface either holds it in its inactive state, or does not drive it (leaves it in high-impedance state). |
| SSEL0/1 | I/O  | SSEL                        | FS             | CS             | Frame Sync/Slave Select. When the SSPn interface is a bus master, it drives this signal to an active state before the start of serial data, and then releases it to an inactive state after the serial data has been sent. The active state of this signal can be high or low depending upon the selected bus and mode. When the SSPn is a bus slave, this signal qualifies the presence of data from the Master, according to the protocol in use.      |
|         |      |                             |                |                | When there is just one bus master and one bus slave, the Frame Sync or Slave Select signal from the Master can be connected directly to the slave's corresponding input. When there is more than one slave on the bus, further qualification of their Frame Select/Slave Select inputs will typically be necessary to prevent more than one slave from responding to a transfer.                                                                         |
| MISO0/1 | I/O  | MISO                        | DR(M)<br>DX(S) | SI(M)<br>SO(S) | Master In Slave Out. The MISO signal transfers serial data from the slave to the master. When the SSPn is a slave, serial data is output on this signal. When the SSPn is a master, it clocks in serial data from this signal. When the SSPn is a slave and is not selected by FS/SSEL, it does not drive this signal (leaves it in high-impedance state).                                                                                               |
| MOSI0/1 | I/O  | MOSI                        | DX(M)<br>DR(S) | SO(M)<br>SI(S) | <b>Master Out Slave In.</b> The MOSI signal transfers serial data from the master to the slave. When the SSPn is a master, it outputs serial data on this signal. When the SSPn is a slave, it clocks in serial data from this signal.                                                                                                                                                                                                                   |

### 18.5 Bus description

### 18.5.1 Texas Instruments synchronous serial frame format

Figure 77 shows the 4-wire Texas Instruments synchronous serial frame format supported by the SSP module.

© NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers User manual Rev. 4. 1 - 19 December 2016 424 of 851 NXP Semiconductors UM10360

Chapter 18: LPC176x/5x SSP0/1



For device configured as a master in this mode, CLK and FS are forced LOW, and the transmit data line DX is tri-stated whenever the SSP is idle. Once the bottom entry of the transmit FIFO contains data, FS is pulsed HIGH for one CLK period. The value to be transmitted is also transferred from the transmit FIFO to the serial shift register of the transmit logic. On the next rising edge of CLK, the MSB of the 4-bit to 16-bit data frame is shifted out on the DX pin. Likewise, the MSB of the received data is shifted onto the DR pin by the off-chip serial slave device.

Both the SSP and the off-chip serial slave device then clock each data bit into their serial shifter on the falling edge of each CLK. The received data is transferred from the serial shifter to the receive FIFO on the first rising edge of CLK after the LSB has been latched.

#### 18.5.2 SPI frame format

The SPI interface is a four-wire interface where the SSEL signal behaves as a slave select. The main feature of the SPI format is that the inactive state and phase of the SCK signal are programmable through the CPOL and CPHA bits within the SSPCR0 control register.

#### 18.5.2.1 Clock Polarity (CPOL) and Phase (CPHA) control

When the CPOL clock polarity control bit is 0, it produces a steady state low value on the SCK pin. If the CPOL clock polarity control bit is 1, a steady state high value is placed on the CLK pin when data is not being transferred.

NXP Semiconductors UM10360

The CPHA control bit selects the clock edge that captures data and allows it to change state. It has the most impact on the first bit transmitted by either allowing or not allowing a clock transition before the first data capture edge. When the CPHA phase control bit is 0, data is captured on the first clock edge transition. If the CPHA clock phase control bit is 1, data is captured on the second clock edge transition.

Chapter 18: LPC176x/5x SSP0/1

### 18.5.2.2 SPI format with CPOL=0,CPHA=0

Single and continuous transmission signal sequences for SPI format with CPOL = 0, CPHA = 0 are shown in Figure 78.



In this configuration, during idle periods:

- . The CLK signal is forced LOW.
- . SSEL is forced HIGH.
- The transmit MOSI/MISO pad is in high impedance.

If the SSP is enabled and there is valid data within the transmit FIFO, the start of transmission is signified by the SSEL master signal being driven LOW. This causes slave data to be enabled onto the MISO input line of the master. Master's MOSI is enabled.

One half SCK period later, valid master data is transferred to the MOSI pin. Now that both the master and slave data have been set, the SCK master clock pin goes HIGH after one further half SCK period.

The data is now captured on the rising and propagated on the falling edges of the SCK signal.

UM10360 All information provided in this document is subject to legal disclaimers. 0100FB.V. 2016. All rights reserved.

User manual Rev. 4.1—19 December 2016 425 of 851
User manual Rev. 4.1—19 December 2016 426 of 851

UM10360 **NXP Semiconductors** 

Chapter 18: LPC176x/5x SSP0/1

In the case of a single word transmission, after all bits of the data word have been transferred, the SSEL line is returned to its idle HIGH state one SCK period after the last bit has been captured.

However, in the case of continuous back-to-back transmissions, the SSEL signal must be pulsed HIGH between each data word transfer. This is because the slave select pin freezes the data in its serial peripheral register and does not allow it to be altered if the CPHA bit is logic zero. Therefore the master device must raise the SSEL pin of the slave device between each data transfer to enable the serial peripheral data write. On completion of the continuous transfer, the SSEL pin is returned to its idle state one SCK period after the last bit has been captured.

#### 18.5.2.3 SPI format with CPOL=0,CPHA=1

The transfer signal sequence for SPI format with CPOL = 0, CPHA = 1 is shown in Figure 79, which covers both single and continuous transfers.



In this configuration, during idle periods:

- . The CLK signal is forced LOW.
- SSEL is forced HIGH.
- The transmit MOSI/MISO pad is in high impedance.

If the SSP is enabled and there is valid data within the transmit FIFO, the start of transmission is signified by the SSEL master signal being driven LOW. Master's MOSI pin is enabled. After a further one half SCK period, both master and slave valid data is enabled onto their respective transmission lines. At the same time, the SCK is enabled with a rising edge transition.

Data is then captured on the falling edges and propagated on the rising edges of the SCK signal.

In the case of a single word transfer, after all bits have been transferred, the SSEL line is returned to its idle HIGH state one SCK period after the last bit has been captured.

For continuous back-to-back transfers, the SSEL pin is held LOW between successive data words and termination is the same as that of the single word transfer.

#### 18.5.2.4 SPI format with CPOL = 1,CPHA = 0

UM10360

User manual

Single and continuous transmission signal sequences for SPI format with CPOL=1, CPHA=0 are shown in Figure 80.

UM10360 **NXP Semiconductors** Chapter 18: LPC176x/5x SSP0/1

### 18.6 Register description

The register addresses of the SSP controllers addresses are shown in Table 370.

Table 370. SSP Register Map

| Generic Name         Description         Access Value <sup>(1)</sup> Reset Value <sup>(1)</sup> SSPn Register Name & Address           CR0         Control Register 0. Selects the serial clock rate, bus type, and data size.         R/W         0         SSP0CR0 - 0x4008 8000 SSP1CR0 - 0x4003 0000 SSP1CR1 - 0x4003 0004 SSP1CR1 - 0x4003 0006 SSP1CR1 - 0x4003 0008 SSP1CR1 - 0x4003 0008 SSP1CR1 - 0x4003 0006 SSP1CR1 - 0x4003 0006 SSP1CR1 - 0x4003 000C SSP1SR - 0x4003 000C SSP1SR - 0x4003 000C SSP1SR - 0x4003 000C SSP1SR - 0x4003 000C SSP1CR2 - 0x4003 000C SSP1CR2 - 0x4003 000C SSP1CR2 - 0x4003 0014 SSP1CR2 - 0x4003 0014 SSP1CR2 - 0x4003 0014 SSP1CR2 - 0x4003 0018 SSP1CR2 - 0x4003 0018 SSP1CR2 - 0x4003 0018 SSP1CR2 - 0x4003 0016 SSP1CR2 - 0x4003 0010 SSP1CR2 - 0x4003 0010 SSP1CR2 - 0x4003 0010 SSP1CR2 - 0x4003 0020 SSP1CR2 |       | . oo. map                             |        |    |                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------------------|--------|----|----------------------------------------------------|
| Serial clock rate, bus type, and data size.   SSP1CR0 - 0x4003 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       | Description                           | Access |    |                                                    |
| master/slave and other modes.         SSP1CR1 - 0x4003 0004           DR         Data Register. Writes fill the transmit FIFO, and reads empty the receive FIFO.         0         SSP0DR - 0x4008 8008 SSP1DR - 0x4003 0008           SR         Status Register         RO         SSP0SR - 0x4008 800C SSP1SR - 0x4003 000C SSP1SR - 0x4003 000C SSP1SR - 0x4003 0010           CPSR         Clock Prescale Register         R/W         0         SSP0CPSR - 0x4008 8010 SSP1CPSR - 0x4003 0010           IMSC         Interrupt Mask Set and Clear Register         R/W         0         SSP0IMSC - 0x4003 0014           RIS         Raw Interrupt Status Register         R/W         SSP0RIS - 0x4003 0018 SSP1RIS - 0x4003 0018           MIS         Masked Interrupt Status Register         R/W         0         SSP0MIS - 0x4008 801C SSP1MIS - 0x4003 001C           ICR         SSPICR Interrupt Clear Register         R/W         NA         SSP0ICR - 0x4003 0020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CR0   | serial clock rate, bus type, and data | R/W    | 0  |                                                    |
| transmit FIFO, and reads empty the receive FIFO.         SSP1DR - 0x4003 0008           SR         Status Register         RO         SSP0SR - 0x4008 800C SSP1SR - 0x4003 000C           CPSR         Clock Prescale Register         R/W         0         SSP0CPSR - 0x4003 8010 SSP1CPSR - 0x4003 0010           IMSC         Interrupt Mask Set and Clear Register         R/W         0         SSP0IMSC - 0x4008 8014 SSP1IMSC - 0x4003 0014           RIS         Raw Interrupt Status Register         R/W         SSP0RIS - 0x4003 0018 SSP1RIS - 0x4003 0018           MIS         Masked Interrupt Status Register         R/W         0         SSP0MIS - 0x4003 001C SSP1MIS - 0x4003 001C           ICR         SSPICR Interrupt Clear Register         R/W         NA         SSP0ICR - 0x4003 8020 SSP1ICR - 0x4003 0020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CR1   |                                       | R/W    | 0  |                                                    |
| SSP1SR - 0x4003 000C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DR    | transmit FIFO, and reads empty        | R/W    | 0  |                                                    |
| SSP1CPSR - 0x4003 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SR    | Status Register                       | RO     |    |                                                    |
| Register         SSP1IMSC - 0x4003 0014           RIS         Raw Interrupt Status Register         R/W         SSP0RIS - 0x4008 8018 SSP1RIS - 0x4003 0018           MIS         Masked Interrupt Status Register         R/W         0         SSP0MIS - 0x4008 801C SSP1MIS - 0x4008 801C SSP1MIS - 0x4008 801C           ICR         SSPICR Interrupt Clear Register         R/W         NA         SSP0ICR - 0x4008 8020 SSP1ICR - 0x4003 0020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CPSR  | Clock Prescale Register               | R/W    | 0  |                                                    |
| SSP1RIS - 0x4003 0018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | IMSC  |                                       | R/W    | 0  |                                                    |
| SSP1MIS - 0x4003 001C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RIS   | Raw Interrupt Status Register         | R/W    |    |                                                    |
| SSP1ICR - 0x4003 0020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MIS   | Masked Interrupt Status Register      | R/W    | 0  |                                                    |
| DMACR DMA Control Register R/W 0 SSP0DMACR - 0x4008 802                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ICR   | SSPICR Interrupt Clear Register       | R/W    | NA |                                                    |
| SSP1DMACR - 0x4003 002                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMACR | DMA Control Register                  | R/W    | 0  | SSP0DMACR - 0x4008 8024<br>SSP1DMACR - 0x4003 0024 |

<sup>[1]</sup> Reset Value reflects the data stored in used bits only. It does not include reserved bits content.

# 18.6.1 SSPn Control Register 0 (SSP0CR0 - 0x4008 8000, SSP1CR0 - 0x4003

This register controls the basic operation of the SSP controller.

© NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers © NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers Rev. 4. 1 - 19 December 2016 427 of 851 User manual Rev. 4. 1 - 19 December 2016 432 of 851

**UM10360 NXP Semiconductors** 

Chapter 18: LPC176x/5x SSP0/1

433 of 851

Table 371: SSPn Control Register 0 (SSP0CR0 - address 0x4008 8000, SSP1CR0 - 0x4003 0000) bit description

| Bit  | Symbol | Value | Description                                                                                                                                                                                                                              | Reset<br>Value |
|------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0  | DSS    |       | Data Size Select. This field controls the number of bits transferred in each frame. Values 0000-0010 are not supported and should not be used.                                                                                           | 0000           |
|      |        | 0011  | 4-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 0100  | 5-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 0101  | 6-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 0110  | 7-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 0111  | 8-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 1000  | 9-bit transfer                                                                                                                                                                                                                           |                |
|      |        | 1001  | 10-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1010  | 11-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1011  | 12-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1100  | 13-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1101  | 14-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1110  | 15-bit transfer                                                                                                                                                                                                                          |                |
|      |        | 1111  | 16-bit transfer                                                                                                                                                                                                                          |                |
| 5:4  | FRF    |       | Frame Format.                                                                                                                                                                                                                            | 00             |
|      |        | 00    | SPI                                                                                                                                                                                                                                      |                |
|      |        | 01    | TI                                                                                                                                                                                                                                       |                |
|      |        | 10    | Microwire                                                                                                                                                                                                                                |                |
|      |        | 11    | This combination is not supported and should not be used.                                                                                                                                                                                |                |
| 6    | CPOL   |       | Clock Out Polarity. This bit is only used in SPI mode.                                                                                                                                                                                   | 0              |
|      |        | 0     | SSP controller maintains the bus clock low between frames.                                                                                                                                                                               |                |
|      |        | 1     | SSP controller maintains the bus clock high between frames.                                                                                                                                                                              |                |
| 7    | CPHA   |       | Clock Out Phase. This bit is only used in SPI mode.                                                                                                                                                                                      | 0              |
|      |        | 0     | SSP controller captures serial data on the first clock transition of the frame, that is, the transition <b>away from</b> the inter-frame state of the clock line.                                                                        |                |
|      |        | 1     | SSP controller captures serial data on the second clock transition of the frame, that is, the transition <b>back to</b> the inter-frame state of the clock line.                                                                         |                |
| 15:8 | SCR    |       | Serial Clock Rate. The number of prescaler-output clocks per bit on the bus, minus one. Given that CPSDVSR is the prescale divider, and the APB clock PCLK clocks the prescaler, the bit frequency is PCLK / (CPSDVSR $\times$ [SCR+1]). | 0x00           |
| 31:8 | -      |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                       | NA             |

# 18.6.2 SSPn Control Register 1 (SSP0CR1 - 0x4008 8004, SSP1CR1 -0x4003 0004)

This register controls certain aspects of the operation of the SSP controller.

© NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers. UM10360 Rev. 4. 1 - 19 December 2016

User manual

**UM10360 NXP Semiconductors** 

Chapter 18: LPC176x/5x SSP0/1

Table 372: SSPn Control Register 1 (SSP0CR1 - address 0x4008 8004, SSP1CR1 - 0x4003 0004) bit description

| Bit  | Symbol | Value                                                              | Description                                                                                                                                                                                                              | Reset<br>Value |
|------|--------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | LBM    |                                                                    | Loop Back Mode.                                                                                                                                                                                                          | 0              |
|      |        | 0                                                                  | During normal operation.                                                                                                                                                                                                 |                |
|      |        | 1                                                                  | Serial input is taken from the serial output (MOSI or MISO) rather than the serial input pin (MISO or MOSI respectively).                                                                                                |                |
| 1    | SSE    |                                                                    | SSP Enable.                                                                                                                                                                                                              | 0              |
|      |        | 0                                                                  | The SSP controller is disabled.                                                                                                                                                                                          |                |
|      |        | 1                                                                  | The SSP controller will interact with other devices on the serial bus. Software should write the appropriate control information to the other SSP registers and interrupt controller registers, before setting this bit. |                |
| 2    | MS     | is 0.  The SSP controller acts as a master on the bus, driving the | Master/Slave Mode.This bit can only be written when the SSE bit is 0. $ \\$                                                                                                                                              | 0              |
|      |        |                                                                    | The SSP controller acts as a master on the bus, driving the SCLK, MOSI, and SSEL lines and receiving the MISO line.                                                                                                      |                |
|      |        | 1                                                                  | The SSP controller acts as a slave on the bus, driving MISO line and receiving SCLK, MOSI, and SSEL lines.                                                                                                               |                |
| 3    | SOD    |                                                                    | Slave Output Disable. This bit is relevant only in slave mode (MS = 1). If it is 1, this blocks this SSP controller from driving the transmit data line (MISO).                                                          | 0              |
| 31:4 | -      |                                                                    | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                       | NA             |

# 18.6.3 SSPn Data Register (SSP0DR - 0x4008 8008, SSP1DR - 0x4003 0008)

Software can write data to be transmitted to this register, and read data that has been received.

Table 373: SSPn Data Register (SSP0DR - address 0x4008 8008, SSP1DR - 0x4003 0008) bit description

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset<br>Value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | DATA   | Write: software can write data to be sent in a future frame to this register whenever the TNF bit in the Status register is 1, indicating that the Tx FIFO is not full. If the Tx FIFO was previously empty and the SSP controller is not busy on the bus, transmission of the data will begin immediately. Otherwise the data written to this register will be sent as soon as all previous data has been sent (and received). If the data length is less than 16 bits, software must right-justify the data written to this register. | 0x0000         |
|       |        | Read: software can read data from this register whenever the RNE bit in the Status register is 1, indicating that the Rx FIFO is not empty. When software reads this register, the SSP controller returns data from the least recent frame in the Rx FIFO. If the data length is less than 16 bits, the data is right-justified in this field with higher order bits filled with 0s.                                                                                                                                                    |                |
| 31:16 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                                                                                      | NA             |

© NXP B.V. 2016. All rights reserved. All information provided in this document is subject to legal disclaimers. User manual Rev. 4. 1 — 19 December 2016 434 of 851 NXP Semiconductors UM10360

Chapter 18: LPC176x/5x SSP0/1

# 18.6.4 SSPn Status Register (SSP0SR - 0x4008 800C, SSP1SR - 0x4003 000C)

This read-only register reflects the current status of the SSP controller.

Table 374: SSPn Status Register (SSP0SR - address 0x4008 800C, SSP1SR - 0x4003 000C) bit description

|      |        | Compton                                                                                                                                |                |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Bit  | Symbol | Description                                                                                                                            | Reset<br>Value |
| 0    | TFE    | Transmit FIFO Empty. This bit is 1 is the Transmit FIFO is empty, 0 if not.                                                            | 1              |
| 1    | TNF    | Transmit FIFO Not Full. This bit is 0 if the Tx FIFO is full, 1 if not.                                                                | 1              |
| 2    | RNE    | Receive FIFO Not Empty. This bit is 0 if the Receive FIFO is empty, 1 if not.                                                          | 0              |
| 3    | RFF    | Receive FIFO Full. This bit is 1 if the Receive FIFO is full, 0 if not.                                                                | 0              |
| 4    | BSY    | Busy. This bit is 0 if the SSPn controller is idle, or 1 if it is currently sending/receiving a frame and/or the Tx FIFO is not empty. | 0              |
| 31:5 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                     | NA             |

# 18.6.5 SSPn Clock Prescale Register (SSP0CPSR - 0x4008 8010, SSP1CPSR - 0x4003 0010)

This register controls the factor by which the Prescaler divides the SSP peripheral clock SSP\_PCLK to yield the prescaler clock that is, in turn, divided by the SCR factor in SSPnCR0, to determine the bit clock.

Table 375: SSPn Clock Prescale Register (SSP0CPSR - address 0x4008 8010, SSP1CPSR - 0x4003 0010) bit description

| Bit  | Symbol  | Description                                                                                                                   | Reset<br>Value |
|------|---------|-------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | CPSDVSR | This even value between 2 and 254, by which SSP_PCLK is divided to yield the prescaler output clock. Bit 0 always reads as 0. | 0              |
| 31:8 | -       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.            | NA             |

Important: the SSPnCPSR value must be properly initialized or the SSP controller will not be able to transmit data correctly.

In Slave mode, the SSP clock rate provided by the master must not exceed 1/12 of the SSP peripheral clock selected in <u>Section 4.7.3</u>. The content of the SSPnCPSR register is not relevant.

In master mode, CPSDVSR<sub>min</sub> = 2 or larger (even numbers only).

# 18.6.6 SSPn Interrupt Mask Set/Clear Register (SSP0IMSC - 0x4008 8014, SSP1IMSC - 0x4003 0014)

This register controls whether each of the four possible interrupt conditions in the SSP controller are enabled. Note that ARM uses the word "masked" in the opposite sense from classic computer terminology, in which "masked" meant "disabled". ARM uses the word "masked" to mean "enabled". To avoid confusion we will not use the word "masked".

NXP Semiconductors UM10360

Table 376: SSPn Interrupt Mask Set/Clear register (SSP0IMSC - address 0x4008 8014, SSP1IMSC - 0x4003 0014) bit description

Chapter 18: LPC176x/5x SSP0/1

|      |        | , .                                                                                                                                                                                                                                                                                                                                                   |                |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                                           | Reset<br>Value |
| 0    | RORIM  | Software should set this bit to enable interrupt when a Receive Overrun occurs, that is, when the Rx FIFO is full and another frame is completely received. The ARM spec implies that the preceding frame data is overwritten by the new frame data when this occurs.                                                                                 | 0              |
| 1    | RTIM   | Software should set this bit to enable interrupt when a Receive Time-out condition occurs. A Receive Time-out occurs when the Rx FIFO is not empty, and no has not been read for a "time-out period". The time-out period is the same for master and slave modes and is determined by the SSP bit rate: 32 bits at PCLK / (CPSDVSR $\times$ [SCR+1]). | 0              |
| 2    | RXIM   | Software should set this bit to enable interrupt when the Rx FIFO is at least half full.                                                                                                                                                                                                                                                              | 0              |
| 3    | TXIM   | Software should set this bit to enable interrupt when the Tx FIFO is at least half empty.                                                                                                                                                                                                                                                             | 0              |
| 31:4 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                    | NA             |

# 18.6.7 SSPn Raw Interrupt Status Register (SSP0RIS - 0x4008 8018, SSP1RIS - 0x4003 0018)

This read-only register contains a 1 for each interrupt condition that is asserted, regardless of whether or not the interrupt is enabled in the SSPnIMSC.

Table 377: SSPn Raw Interrupt Status register (SSP0RIS - address 0x4008 8018, SSP1RIS - 0x4003 0018) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                        | Reset<br>Value |
|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | RORRIS | This bit is 1 if another frame was completely received while the RxFIFO was full. The ARM spec implies that the preceding frame data is overwritten by the new frame data when this occurs.                                        | 0              |
| 1    | RTRIS  | This bit is 1 if the Rx FIFO is not empty, and has not been read for a "time-out period". The time-out period is the same for master and slave modes and is determined by the SSP bit rate: 32 bits at PCLK / (CPSDVSR × [SCR+1]). | 0              |
| 2    | RXRIS  | This bit is 1 if the Rx FIFO is at least half full.                                                                                                                                                                                | 0              |
| 3    | TXRIS  | This bit is 1 if the Tx FIFO is at least half empty.                                                                                                                                                                               | 1              |
| 31:4 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                 | NA             |

# 18.6.8 SSPn Masked Interrupt Status Register (SSP0MIS - 0x4008 801C, SSP1MIS - 0x4003 001C)

This read-only register contains a 1 for each interrupt condition that is asserted and enabled in the SSPnIMSC. When an SSP interrupt occurs, the interrupt service routine should read this register to determine the cause(s) of the interrupt.

UM10360 All information provided in this document is subject to legal disclaimers. © NXP B. V. 2016. All rights reserved,

UM10360 All information provided in this document is subject to legal disclaimers. © NXP B. V. 2016. All rights reserved.

User manual Rev. 4. 1 — 19 December 2016 435 of 851 User manual Rev. 4. 1 — 19 December 2016 436 of 851

UM10360 **NXP Semiconductors** 

Chapter 18: LPC176x/5x SSP0/1

Table 378: SSPn Masked Interrupt Status register (SSPnMIS -address 0x4008 801C, SSP1MIS - 0x4003 001C) bit description

|      | , , , , , , , , , , , , , , , , , , , , |                                                                                                                                                                                                                                                               |                |  |  |
|------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| Bit  | Symbol                                  | Description                                                                                                                                                                                                                                                   | Reset<br>Value |  |  |
| 0    | RORMIS                                  | This bit is 1 if another frame was completely received while the RxFIFO was full, and this interrupt is enabled.                                                                                                                                              | 0              |  |  |
| 1    | RTMIS                                   | This bit is 1 if the Rx FIFO is not empty, has not been read for a "time-out period", and this interrupt is enabled. The time-out period is the same for master and slave modes and is determined by the SSP bit rate: 32 bits at PCLK / (CPSDVSR × (SCR+1)). | 0              |  |  |
| 2    | RXMIS                                   | This bit is 1 if the Rx FIFO is at least half full, and this interrupt is enabled.                                                                                                                                                                            | 0              |  |  |
| 3    | TXMIS                                   | This bit is 1 if the Tx FIFO is at least half empty, and this interrupt is enabled.                                                                                                                                                                           | 0              |  |  |
| 31:4 | -                                       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                            | NA             |  |  |

### 18.6.9 SSPn Interrupt Clear Register (SSP0ICR - 0x4008 8020, SSP1ICR -0x4003 0020)

Software can write one or more one(s) to this write-only register, to clear the corresponding interrupt condition(s) in the SSP controller. Note that the other two interrupt conditions can be cleared by writing or reading the appropriate FIFO, or disabled by clearing the corresponding bit in SSPnIMSC.

Table 379: SSPn interrupt Clear Register (SSP0ICR - address 0x4008 8020, SSP1ICR -0x4003 0020) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                                                | Reset<br>Value |
|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | RORIC  | Writing a 1 to this bit clears the "frame was received when RxFIFO was full" interrupt.                                                                                                                                                                    | NA             |
| 1    | RTIC   | Writing a 1 to this bit clears the "Rx FIFO was not empty and has not been read for a time-out period" interrupt. The time-out period is the same for master and slave modes and is determined by the SSP bit rate: 32 bits at PCLK / (CPSDVSR × [SCR+1]). | NA             |
| 31:2 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                         | NA             |

### 18.6.10 SSPn DMA Control Register (SSP0DMACR - 0x4008 8024, SSP1DMACR - 0x4003 0024)

The SSPnDMACR register is the DMA control register. It is a read/write register.

All information provided in this document is subject to legal disclaimers User manual Rev. 4. 1 - 19 December 2016



